## Microcontroller Engineering I

## **Examination Data Booklet**

## Do NOT write on this Data Booklet

The following pages are reproduced from the Microchip PIC18F8722 datasheet (DS39646C) with the permission of Microchip Technology Inc.

This material remains the copyright of Microchip Technology Inc.

### **Microcontroller Board Schematic**



Circuit Diagrams of the Input/Output Board











#### 5.3.4 SPECIAL FUNCTION REGISTERS

The Special Function Registers (SFRs) are registers used by the CPU and peripheral modules for controlling the desired operation of the device. These registers are implemented as static RAM. SFRs start at the top of data memory (FFFh) and extend downward to occupy the top half of Bank 15 (F60h to FFFh). A list of these registers is given in Table 5-2 and Table 5-3.

The SFRs can be classified into two sets: those associated with the "core" device functionality (ALU, Resets and interrupts) and those related to the peripheral functions. The Reset and interrupt registers are described in their respective chapters, while the ALU's STATUS register is described later in this section. Registers related to the operation of a peripheral feature are described in the chapter for that peripheral.

The SFRs are typically distributed among the peripherals whose functions they control. Unused SFR locations are unimplemented and read as '0's.

TABLE 5-2: SPECIAL FUNCTION REGISTER MAP FOR THE PIC18F8722 FAMILY OF DEVICES

| Address | Name                    | Address | Name                    | Address | Name                  | Address | Name                 | Address | Name     |
|---------|-------------------------|---------|-------------------------|---------|-----------------------|---------|----------------------|---------|----------|
| FFFh    | TOSU                    | FDFh    | INDF2 <sup>(1)</sup>    | FBFh    | CCPR1H                | F9Fh    | IPR1                 | F7Fh    | SPBRGH1  |
| FFEh    | TOSH                    | FDEh    | POSTINC2 <sup>(1)</sup> | FBEh    | CCPR1L                | F9Eh    | PIR1                 | F7Eh    | BAUDCON1 |
| FFDh    | TOSL                    | FDDh    | POSTDEC2 <sup>(1)</sup> | FBDh    | CCP1CON               | F9Dh    | PIE1                 | F7Dh    | SPBRGH2  |
| FFCh    | STKPTR                  | FDCh    | PREINC2 <sup>(1)</sup>  | FBCh    | CCPR2H                | F9Ch    | MEMCON               | F7Ch    | BAUDCON2 |
| FFBh    | PCLATU                  | FDBh    | PLUSW2 <sup>(1)</sup>   | FBBh    | CCPR2L                | F9Bh    | OSCTUNE              | F7Bh    | (2)      |
| FFAh    | PCLATH                  | FDAh    | FSR2H                   | FBAh    | CCP2CON               | F9Ah    | TRISJ <sup>(3)</sup> | F7Ah    | (2)      |
| FF9h    | PCL                     | FD9h    | FSR2L                   | FB9h    | CCPR3H                | F99h    | TRISH <sup>(3)</sup> | F79h    | ECCP1DEL |
| FF8h    | TBLPTRU                 | FD8h    | STATUS                  | FB8h    | CCPR3L                | F98h    | TRISG                | F78h    | TMR4     |
| FF7h    | TBLPTRH                 | FD7h    | TMR0H                   | FB7h    | CCP3CON               | F97h    | TRISF                | F77h    | PR4      |
| FF6h    | TBLPTRL                 | FD6h    | TMR0L                   | FB6h    | ECCP1AS               | F96h    | TRISE                | F76h    | T4CON    |
| FF5h    | TABLAT                  | FD5h    | T0CON                   | FB5h    | CVRCON                | F95h    | TRISD                | F75h    | CCPR4H   |
| FF4h    | PRODH                   | FD4h    | (2)                     | FB4h    | CMCON                 | F94h    | TRISC                | F74h    | CCPR4L   |
| FF3h    | PRODL                   | FD3h    | OSCCON                  | FB3h    | TMR3H                 | F93h    | TRISB                | F73h    | CCP4CON  |
| FF2h    | INTCON                  | FD2h    | HLVDCON                 | FB2h    | TMR3L                 | F92h    | TRISA                | F72h    | CCPR5H   |
| FF1h    | INTCON2                 | FD1h    | WDTCON                  | FB1h    | T3CON                 | F91h    | LATJ <sup>(3)</sup>  | F71h    | CCPR5L   |
| FF0h    | INTCON3                 | FD0h    | RCON                    | FB0h    | PSPCON                | F90h    | LATH <sup>(3)</sup>  | F70h    | CCP5CON  |
| FEFh    | INDF0 <sup>(1)</sup>    | FCFh    | TMR1H                   | FAFh    | SPBRG1                | F8Fh    | LATG                 | F6Fh    | SPBRG2   |
| FEEh    | POSTINCO <sup>(1)</sup> | FCEh    | TMR1L                   | FAEh    | RCREG1                | F8Eh    | LATF                 | F6Eh    | RCREG2   |
| FEDh    | POSTDEC0 <sup>(1)</sup> | FCDh    | T1CON                   | FADh    | TXREG1                | F8Dh    | LATE                 | F6Dh    | TXREG2   |
| FECh    | PREINC0 <sup>(1)</sup>  | FCCh    | TMR2                    | FACh    | TXSTA1                | F8Ch    | LATD                 | F6Ch    | TXSTA2   |
| FEBh    | PLUSW0 <sup>(1)</sup>   | FCBh    | PR2                     | FABh    | RCSTA1                | F8Bh    | LATC                 | F6Bh    | RCSTA2   |
| FEAh    | FSR0H                   | FCAh    | T2CON                   | FAAh    | EEADRH                | F8Ah    | LATB                 | F6Ah    | ECCP3AS  |
| FE9h    | FSR0L                   | FC9h    | SSP1BUF                 | FA9h    | EEADR                 | F89h    | LATA                 | F69h    | ECCP3DEL |
| FE8h    | WREG                    | FC8h    | SSP1ADD                 | FA8h    | EEDATA                | F88h    | PORTJ <sup>(3)</sup> | F68h    | ECCP2AS  |
| FE7h    | INDF1 <sup>(1)</sup>    | FC7h    | SSP1STAT                | FA7h    | EECON2 <sup>(1)</sup> | F87h    | PORTH <sup>(3)</sup> | F67h    | ECCP2DEL |
| FE6h    | POSTINC1 <sup>(1)</sup> | FC6h    | SSP1CON1                | FA6h    | EECON1                | F86h    | PORTG                | F66h    | SSP2BUF  |
| FE5h    | POSTDEC1 <sup>(1)</sup> | FC5h    | SSP1CON2                | FA5h    | IPR3                  | F85h    | PORTF                | F65h    | SSP2ADD  |
| FE4h    | PREINC1 <sup>(1)</sup>  | FC4h    | ADRESH                  | FA4h    | PIR3                  | F84h    | PORTE                | F64h    | SSP2STAT |
| FE3h    | PLUSW1 <sup>(1)</sup>   | FC3h    | ADRESL                  | FA3h    | PIE3                  | F83h    | PORTD                | F63h    | SSP2CON1 |
| FE2h    | FSR1H                   | FC2h    | ADCON0                  | FA2h    | IPR2                  | F82h    | PORTC                | F62h    | SSP2CON2 |
| FE1h    | FSR1L                   | FC1h    | ADCON1                  | FA1h    | PIR2                  | F81h    | PORTB                | F61h    | (2)      |
| FE0h    | BSR                     | FC0h    | ADCON2                  | FA0h    | PIE2                  | F80h    | PORTA                | F60h    | (2)      |

Note 1: This is not a physical register.

- 2: Unimplemented registers are read as '0'.
- 3: This register is not available on 64-pin devices.

### TABLE 26-1: OPCODE FIELD DESCRIPTIONS

| Field           | Description                                                                                                                                  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| a               | RAM access bit:                                                                                                                              |
|                 | a = 0: RAM location in Access RAM (BSR register is ignored)                                                                                  |
|                 | a = 1: RAM bank is specified by BSR register                                                                                                 |
| bbb             | Bit address within an 8-bit file register (0 to 7).                                                                                          |
| BSR             | Bank Select Register. Used to select the current RAM bank.                                                                                   |
| C, DC, Z, OV, N | ALU status bits: Carry, Digit Carry, Zero, Overflow, Negative.                                                                               |
| d               | Destination select bit:                                                                                                                      |
|                 | d = 0: store result in WREG d = 1: store result in file register f                                                                           |
| dest            | Destination: either the WREG register or the specified register file location.                                                               |
| f               | 8-bit Register file address (00h to FFh), or 2-bit FSR designator (0h to 3h).                                                                |
| f <sub>s</sub>  | 12-bit Register file address (000h to FFFh). This is the source address.                                                                     |
| f <sub>d</sub>  | 12-bit Register file address (000h to FFFh). This is the destination address.                                                                |
| GIE             | Global Interrupt Enable bit.                                                                                                                 |
| k               | Literal field, constant data or label (may be either an 8-bit, 12-bit or a 20-bit value).                                                    |
| label           | Label name.                                                                                                                                  |
| mm              | The mode of the TBLPTR register for the table read and table write instructions.                                                             |
|                 | Only used with table read and table write instructions:                                                                                      |
| *               | No Change to register (such as TBLPTR with table reads and writes)                                                                           |
| *+              | Post-Increment register (such as TBLPTR with table reads and writes)                                                                         |
| *_              | Post-Decrement register (such as TBLPTR with table reads and writes)                                                                         |
| +*              | Pre-Increment register (such as TBLPTR with table reads and writes)                                                                          |
|                 |                                                                                                                                              |
| n               | The relative address (2's complement number) for relative branch instructions or the direct address for Call/Branch and Return instructions. |
| PC              | Program Counter.                                                                                                                             |
| PCL             | Program Counter Low Byte.                                                                                                                    |
| PCH             | Program Counter High Byte.                                                                                                                   |
| PCLATH          | Program Counter High Byte Latch.                                                                                                             |
| PCLATU          | Program Counter Upper Byte Latch.                                                                                                            |
| PD              | Power-Down bit.                                                                                                                              |
| PRODH           | Product of Multiply High Byte.                                                                                                               |
| PRODL           | Product of Multiply Low Byte.                                                                                                                |
| S               | Fast Call/Return mode select bit:                                                                                                            |
|                 | s = 0: do not update into/from shadow registers                                                                                              |
|                 | s = 1: certain registers loaded into/from shadow registers (Fast mode)  21-bit Table Pointer (points to a Program Memory location).          |
| TBLPTR          |                                                                                                                                              |
| TABLAT          | 8-bit Table Latch.  Time-out bit.                                                                                                            |
| TO              | Top-of-Stack.                                                                                                                                |
| TOS             | '                                                                                                                                            |
| u<br>wom        | Unused or Unchanged.  Watchdog Timer.                                                                                                        |
| WDT             | Watchdog rimer.  Working register (accumulator).                                                                                             |
| WREG            | Don't care ('0' or '1'). The assembler will generate code with x = 0. It is the recommended form of use for                                  |
| Х               | compatibility with all Microchip software tools.                                                                                             |
| Z <sub>S</sub>  | 7-bit offset value for Indirect Addressing of register files (source).                                                                       |
| z <sub>d</sub>  | 7-bit offset value for Indirect Addressing of register files (destination).                                                                  |
| { }             | Optional argument.                                                                                                                           |
| [text]          | Indicates an indexed address.                                                                                                                |
| (text)          | The contents of text.                                                                                                                        |
| [expr] <n></n>  | Specifies bit n of the register indicated by the pointer expr.                                                                               |
| → ·             | Assigned to.                                                                                                                                 |
| < >             | Register bit field.                                                                                                                          |
| €               | In the set of.                                                                                                                               |
| italics         | User-defined term (font is Courier).                                                                                                         |
| l               |                                                                                                                                              |

#### FIGURE 26-1: GENERAL FORMAT FOR INSTRUCTIONS



TABLE 26-2: PIC18FXXXX INSTRUCTION SET

| Mnemo     | nic,       | Description                              | Cycles     | 16-Bit Instruction Word |      |      | Vord | Status          | Notes      |
|-----------|------------|------------------------------------------|------------|-------------------------|------|------|------|-----------------|------------|
| Operai    | nds        | Description                              | Cycles     | MSb                     |      |      | LSb  | Affected        | Notes      |
| BYTE-ORIE | ENTED C    | PERATIONS                                |            |                         |      |      |      |                 |            |
| ADDWF     | f, d, a    | Add WREG and f                           | 1          | 0010                    | 01da | ffff | ffff | C, DC, Z, OV, N | 1, 2       |
| ADDWFC    | f, d, a    | Add WREG and Carry bit to f              | 1          | 0010                    | 00da | ffff | ffff | C, DC, Z, OV, N | 1, 2       |
| ANDWF     | f, d, a    | AND WREG with f                          | 1          | 0001                    | 01da | ffff | ffff | Z, N            | 1,2        |
| CLRF      | f, a       | Clear f                                  | 1          | 0110                    | 101a | ffff | ffff | Z               | 2          |
| COMF      | f, d, a    | Complement f                             | 1          | 0001                    | 11da | ffff | ffff | Z, N            | 1, 2       |
| CPFSEQ    | f, a       | Compare f with WREG, Skip =              | 1 (2 or 3) | 0110                    | 001a | ffff | ffff | None            | 4          |
| CPFSGT    | f, a       | Compare f with WREG, Skip >              | 1 (2 or 3) | 0110                    | 010a | ffff | ffff | None            | 4          |
| CPFSLT    | f, a       | Compare f with WREG, Skip <              | 1 (2 or 3) | 0110                    | 000a | ffff | ffff | None            | 1, 2       |
| DECF      | f, d, a    | Decrement f                              | 1          | 0000                    | 01da | ffff | ffff | C, DC, Z, OV, N | 1, 2, 3, 4 |
| DECFSZ    | f, d, a    | Decrement f, Skip if 0                   | 1 (2 or 3) | 0010                    | 11da | ffff | ffff | None            | 1, 2, 3, 4 |
| DCFSNZ    | f, d, a    | Decrement f, Skip if Not 0               | 1 (2 or 3) | 0100                    | 11da | ffff | ffff | None            | 1, 2       |
| INCF      | f, d, a    | Increment f                              | 1          | 0010                    | 10da | ffff | ffff | C, DC, Z, OV, N | 1, 2, 3, 4 |
| INCFSZ    | f, d, a    | Increment f, Skip if 0                   | 1 (2 or 3) | 0011                    | 11da | ffff | ffff | None            | 4          |
| INFSNZ    | f, d, a    | Increment f, Skip if Not 0               | 1 (2 or 3) | 0100                    | 10da | ffff | ffff | None            | 1, 2       |
| IORWF     | f, d, a    | Inclusive OR WREG with f                 | 1          | 0001                    | 00da | ffff | ffff | Z, N            | 1, 2       |
| MOVF      | f, d, a    | Move f                                   | 1          | 0101                    | 00da | ffff | ffff | Z, N            | 1          |
| MOVFF     | $f_s, f_d$ | Move f <sub>s</sub> (source) to 1st word | 2          | 1100                    | ffff | ffff | ffff | None            |            |
|           | 3, a       | f <sub>d</sub> (destination) 2nd word    |            | 1111                    | ffff | ffff | ffff |                 |            |
| MOVWF     | f, a       | Move WREG to f                           | 1          | 0110                    | 111a | ffff | ffff | None            |            |
| MULWF     | f, a       | Multiply WREG with f                     | 1          | 0000                    | 001a | ffff | ffff | None            | 1, 2       |
| NEGF      | f, a       | Negate f                                 | 1          | 0110                    | 110a | ffff | ffff | C, DC, Z, OV, N | ,          |
| RLCF      | f, d, a    | Rotate Left f through Carry              | 1          | 0011                    | 01da | ffff | ffff | C, Z, N         | 1, 2       |
| RLNCF     | f, d, a    | Rotate Left f (No Carry)                 | 1          | 0100                    | 01da | ffff | ffff | Z, N            | ,          |
| RRCF      | f, d, a    | Rotate Right f through Carry             | 1          | 0011                    | 00da | ffff | ffff | C, Z, N         |            |
| RRNCF     | f, d, a    | Rotate Right f (No Carry)                | 1          | 0100                    | 00da | ffff | ffff | Z, N            |            |
| SETF      | f, a       | Set f                                    | 1          | 0110                    | 100a | ffff | ffff | None            | 1, 2       |
| SUBFWB    | f, d, a    | Subtract f from WREG with                | 1          | 0101                    | 01da | ffff | ffff | C, DC, Z, OV, N | ,          |
|           | , ,        | Borrow                                   |            |                         |      |      |      |                 |            |
| SUBWF     | f, d, a    | Subtract WREG from f                     | 1          | 0101                    | 11da | ffff | ffff | C, DC, Z, OV, N | 1, 2       |
| SUBWFB    | f, d, a    | Subtract WREG from f with                | 1          | 0101                    | 10da | ffff | ffff | C, DC, Z, OV, N | '          |
|           | . ,        | Borrow                                   |            |                         |      |      |      | , -, -,,        |            |
| SWAPF     | f, d, a    | Swap Nibbles in f                        | 1          | 0011                    | 10da | ffff | ffff | None            | 4          |
| TSTFSZ    | f, a       | Test f, Skip if 0                        | 1 (2 or 3) | 0110                    | 011a | ffff | ffff | None            | 1, 2       |
| XORWF     | f, d, a    | Exclusive OR WREG with f                 | 1          | 0001                    | 10da | ffff | ffff | Z, N            | •          |

- Note 1: When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.
  - 2: If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if assigned.
  - 3: If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.
  - **4:** Some instructions are two-word instructions. The second word of these instructions will be executed as a NOP unless the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program memory locations have a valid instruction.

TABLE 26-2: PIC18FXXXX INSTRUCTION SET (CONTINUED)

| Mnemonic,<br>Operands |         | Description                    | Cycles     | 16-Bit Instruction Word |      |      |      | Status                 | Natas |
|-----------------------|---------|--------------------------------|------------|-------------------------|------|------|------|------------------------|-------|
|                       |         | Description                    | Cycles     | MSb L                   |      |      | LSb  | Affected               | Notes |
| BIT-ORIEN             | ITED OP | ERATIONS                       |            |                         |      |      |      |                        |       |
| BCF                   | f, b, a | Bit Clear f                    | 1          | 1001                    | bbba | ffff | ffff | None                   | 1, 2  |
| BSF                   | f, b, a | Bit Set f                      | 1          | 1000                    | bbba | ffff | ffff | None                   | 1, 2  |
| BTFSC                 | f, b, a | Bit Test f, Skip if Clear      | 1 (2 or 3) | 1011                    | bbba | ffff | ffff | None                   | 3, 4  |
| BTFSS                 | f, b, a | Bit Test f, Skip if Set        | 1 (2 or 3) | 1010                    | bbba | ffff | ffff | None                   | 3, 4  |
| BTG                   | f, b, a | Bit Toggle f                   | 1          | 0111                    | bbba | ffff | ffff | None                   | 1, 2  |
| CONTROL               | OPERA   | TIONS                          | •          | •                       |      |      |      | •                      |       |
| ВС                    | n       | Branch if Carry                | 1 (2)      | 1110                    | 0010 | nnnn | nnnn | None                   |       |
| BN                    | n       | Branch if Negative             | 1 (2)      | 1110                    | 0110 | nnnn | nnnn | None                   |       |
| BNC                   | n       | Branch if Not Carry            | 1 (2)      | 1110                    | 0011 | nnnn | nnnn | None                   |       |
| BNN                   | n       | Branch if Not Negative         | 1 (2)      | 1110                    | 0111 | nnnn | nnnn | None                   |       |
| BNOV                  | n       | Branch if Not Overflow         | 1 (2)      | 1110                    | 0101 | nnnn | nnnn | None                   |       |
| BNZ                   | n       | Branch if Not Zero             | 1 (2)      | 1110                    | 0001 | nnnn | nnnn | None                   |       |
| BOV                   | n       | Branch if Overflow             | 1 (2)      | 1110                    | 0100 | nnnn | nnnn | None                   |       |
| BRA                   | n       | Branch Unconditionally         | 2          | 1101                    | 0nnn | nnnn | nnnn | None                   |       |
| BZ                    | n       | Branch if Zero                 | 1 (2)      | 1110                    | 0000 | nnnn | nnnn | None                   |       |
| CALL                  | n, s    | Call Subroutine 1st word       | 2          | 1110                    | 110s | kkkk | kkkk | None                   |       |
|                       |         | 2nd word                       |            | 1111                    | kkkk | kkkk | kkkk |                        |       |
| CLRWDT                | _       | Clear Watchdog Timer           | 1          | 0000                    | 0000 | 0000 | 0100 | TO, PD                 |       |
| DAW                   | _       | Decimal Adjust WREG            | 1          | 0000                    | 0000 | 0000 | 0111 | С                      |       |
| GOTO                  | n       | Go to Address 1st word         | 2          | 1110                    | 1111 | kkkk | kkkk | None                   |       |
|                       |         | 2nd word                       |            | 1111                    | kkkk | kkkk | kkkk |                        |       |
| NOP                   | _       | No Operation                   | 1          | 0000                    | 0000 | 0000 | 0000 | None                   |       |
| NOP                   | _       | No Operation                   | 1          | 1111                    | XXXX | XXXX | XXXX | None                   | 4     |
| POP                   | _       | Pop Top of Return Stack (TOS)  | 1          | 0000                    | 0000 | 0000 | 0110 | None                   |       |
| PUSH                  | _       | Push Top of Return Stack (TOS) | 1          | 0000                    | 0000 | 0000 | 0101 | None                   |       |
| RCALL                 | n       | Relative Call                  | 2          | 1101                    | 1nnn | nnnn | nnnn | None                   |       |
| RESET                 |         | Software Device Reset          | 1          | 0000                    | 0000 | 1111 | 1111 | All                    |       |
| RETFIE                | S       | Return from Interrupt Enable   | 2          | 0000                    | 0000 | 0001 | 000s | GIE/GIEH,<br>PEIE/GIEL |       |
| RETLW                 | k       | Return with Literal in WREG    | 2          | 0000                    | 1100 | kkkk | kkkk | None                   |       |
| RETURN                | S       | Return from Subroutine         | 2          | 0000                    | 0000 | 0001 | 001s | None_                  |       |
| SLEEP                 | _       | Go into Standby mode           | 1          | 0000                    | 0000 | 0000 | 0011 | TO, PD                 |       |

- **Note 1:** When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.
  - 2: If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if assigned.
  - **3:** If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.
  - **4:** Some instructions are two-word instructions. The second word of these instructions will be executed as a NOP unless the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program memory locations have a valid instruction.

TABLE 26-2: PIC18FXXXX INSTRUCTION SET (CONTINUED)

| Mnemonic,<br>Operands |                | Description                     | Cycles | 16-Bit Instruction Word |      |      |      | Status          | Notes |
|-----------------------|----------------|---------------------------------|--------|-------------------------|------|------|------|-----------------|-------|
|                       |                | Description                     | Cycles | MSb                     |      |      | LSb  | Affected        | Notes |
| LITERAL (             | <b>DPERATI</b> | ONS                             |        |                         |      |      |      |                 |       |
| ADDLW                 | k              | Add Literal and WREG            | 1      | 0000                    | 1111 | kkkk | kkkk | C, DC, Z, OV, N |       |
| ANDLW                 | k              | AND Literal with WREG           | 1      | 0000                    | 1011 | kkkk | kkkk | Z, N            |       |
| IORLW                 | k              | Inclusive OR Literal with WREG  | 1      | 0000                    | 1001 | kkkk | kkkk | Z, N            |       |
| LFSR                  | f, k           | Move Literal (12-bit) 2nd word  | 2      | 1110                    | 1110 | 00ff | kkkk | None            |       |
|                       |                | to FSR(f) 1st word              |        | 1111                    | 0000 | kkkk | kkkk |                 |       |
| MOVLB                 | k              | Move Literal to BSR<3:0>        | 1      | 0000                    | 0001 | 0000 | kkkk | None            |       |
| MOVLW                 | k              | Move Literal to WREG            | 1      | 0000                    | 1110 | kkkk | kkkk | None            |       |
| MULLW                 | k              | Multiply Literal with WREG      | 1      | 0000                    | 1101 | kkkk | kkkk | None            |       |
| RETLW                 | k              | Return with Literal in WREG     | 2      | 0000                    | 1100 | kkkk | kkkk | None            |       |
| SUBLW                 | k              | Subtract WREG from Literal      | 1      | 0000                    | 1000 | kkkk | kkkk | C, DC, Z, OV, N |       |
| XORLW                 | k              | Exclusive OR Literal with WREG  | 1      | 0000                    | 1010 | kkkk | kkkk | Z, N            |       |
| DATAMEN               | /IORY↔I        | PROGRAMMEMORYOPERATION          | ONS    |                         |      |      |      |                 |       |
| TBLRD*                |                | Table Read                      | 2      | 0000                    | 0000 | 0000 | 1000 | None            |       |
| TBLRD*+               |                | Table Read with Post-Increment  |        | 0000                    | 0000 | 0000 | 1001 | None            |       |
| TBLRD*-               |                | Table Read with Post-Decrement  |        | 0000                    | 0000 | 0000 | 1010 | None            |       |
| TBLRD+*               |                | Table Read with Pre-Increment   |        | 0000                    | 0000 | 0000 | 1011 | None            |       |
| TBLWT*                |                | Table Write                     | 2      | 0000                    | 0000 | 0000 | 1100 | None            | 5     |
| TBLWT*+               |                | Table Write with Post-Increment |        | 0000                    | 0000 | 0000 | 1101 | None            | 5     |
| TBLWT*-               |                | Table Write with Post-Decrement |        | 0000                    | 0000 | 0000 | 1110 | None            | 5     |
| TBLWT+*               |                | Table Write with Pre-Increment  |        | 0000                    | 0000 | 0000 | 1111 | None            | 5     |

- Note 1: When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.
  - 2: If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if assigned.
  - **3:** If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.
  - **4:** Some instructions are two-word instructions. The second word of these instructions will be executed as a NOP unless the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program memory locations have a valid instruction.